/* 警告提示组件 - HarmonyOS设计指南实现 */

@import '../base/color.less';
@import '../base/font.less';
@import '../base/window.less';

/* 警告提示变量 */
:root {
  --alert-padding: calc(16 * var(--unit));
  --alert-padding-small: calc(12 * var(--unit));
  --alert-padding-large: calc(20 * var(--unit));
  --alert-border-radius: calc(8 * var(--unit));
  --alert-border-width: 1px;
  --alert-icon-size: calc(20 * var(--unit));
  --alert-icon-size-small: calc(16 * var(--unit));
  --alert-icon-size-large: calc(24 * var(--unit));
  --alert-icon-gap: calc(12 * var(--unit));
  --alert-close-size: calc(20 * var(--unit));
  --alert-close-gap: calc(12 * var(--unit));
  --alert-transition-duration: 0.3s;
}

/* 基础警告提示样式 */
.alert {
  display: flex;
  align-items: flex-start;
  padding: var(--alert-padding);
  border-radius: var(--alert-border-radius);
  border: var(--alert-border-width) solid transparent;
  background-color: var(--color-comp-background-primary);
  color: var(--color-font-primary);
  font-size: var(--font-size-body-medium);
  line-height: 1.5;
  position: relative;
}

.alert-icon {
  flex-shrink: 0;
  width: var(--alert-icon-size);
  height: var(--alert-icon-size);
  margin-right: var(--alert-icon-gap);
  margin-top: calc(2 * var(--unit));
  
  svg {
    width: 100%;
    height: 100%;
    fill: currentColor;
  }
}

.alert-content {
  flex: 1;
  min-width: 0;
}

.alert-title {
  font-size: var(--font-size-title-sub-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-font-primary);
  margin-bottom: calc(4 * var(--unit));
}

.alert-message {
  color: var(--color-font-secondary);
  margin: 0;
}

.alert-close {
  flex-shrink: 0;
  width: var(--alert-close-size);
  height: var(--alert-close-size);
  margin-left: var(--alert-close-gap);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.2s ease;
  color: inherit;
  opacity: 0.7;
  
  &:hover {
    opacity: 1;
    background-color: rgba(0, 0, 0, 0.05);
  }
  
  svg {
    width: calc(14 * var(--unit));
    height: calc(14 * var(--unit));
    fill: currentColor;
  }
}

/* 警告提示尺寸 */
.alert-small,
.alert.small {
  padding: var(--alert-padding-small);
  
  .alert-icon {
    width: var(--alert-icon-size-small);
    height: var(--alert-icon-size-small);
    margin-top: 0;
  }
  
  .alert-title {
    font-size: var(--font-size-title-sub-small);
  }
  
  .alert-message {
    font-size: var(--font-size-body-small);
  }
}

.alert-large,
.alert.large {
  padding: var(--alert-padding-large);
  
  .alert-icon {
    width: var(--alert-icon-size-large);
    height: var(--alert-icon-size-large);
    margin-top: calc(2 * var(--unit));
  }
  
  .alert-title {
    font-size: var(--font-size-title-sub-large);
  }
  
  .alert-message {
    font-size: var(--font-size-body-large);
  }
}

/* 警告提示类型 */
.alert-success,
.alert.success {
  background-color: rgba(100, 187, 92, 0.1);
  border-color: rgba(100, 187, 92, 0.3);
  color: var(--color-confirm);
  
  .alert-icon {
    color: var(--color-confirm);
  }
}

.alert-warning,
.alert.warning {
  background-color: rgba(237, 111, 33, 0.1);
  border-color: rgba(237, 111, 33, 0.3);
  color: var(--color-alert);
  
  .alert-icon {
    color: var(--color-alert);
  }
}

.alert-error,
.alert.error,
.alert.danger {
  background-color: rgba(232, 64, 38, 0.1);
  border-color: rgba(232, 64, 38, 0.3);
  color: var(--color-waring);
  
  .alert-icon {
    color: var(--color-waring);
  }
}

.alert-info,
.alert.info {
  background-color: rgba(10, 89, 247, 0.1);
  border-color: rgba(10, 89, 247, 0.3);
  color: var(--color-brand);
  
  .alert-icon {
    color: var(--color-brand);
  }
}

/* 简洁样式 */
.alert-banner,
.alert.banner {
  border-left: calc(4 * var(--unit)) solid currentColor;
  border-radius: 0;
  
  &.alert-success {
    border-left-color: var(--color-confirm);
  }
  
  &.alert-warning {
    border-left-color: var(--color-alert);
  }
  
  &.alert-error,
  &.alert.danger {
    border-left-color: var(--color-waring);
  }
  
  &.alert-info {
    border-left-color: var(--color-brand);
  }
}

/* 无图标样式 */
.alert-no-icon,
.alert.no-icon {
  .alert-icon {
    display: none;
  }
}

/* 深色模式适配 */
@media (prefers-color-scheme: dark) {
  .alert {
    background-color: var(--color-comp-background-secondary);
  }
  
  .alert-close:hover {
    background-color: rgba(255, 255, 255, 0.1);
  }
}

